package com.fzn.mybatis.mapper;

import com.fzn.mybatis.pojo.User;
import org.apache.ibatis.annotations.MapKey;
import org.apache.ibatis.annotations.Param;

import java.util.List;
import java.util.Map;

/**
 * @program: MyBatis
 * 描述：
 * @author: fzn
 * @create: 2022-03-04 19:37
 **/
public interface SelectMapper {
    /**
     * 根据id查询用户信息
     */
    User getUserById(Integer id);

    /**
     * 查询所有用户
     */
    List<User> getUserList();

    /**
     * 查询记录数
     */
    int getCount();

    /**
     * 查询结果是map集合
     * @param id
     * @return
     */
    Map<String, Object> getUserToMap(@Param("id") int id);

    /**
     * 查询所有用户信息为map集合
     * 查询多个map
     * @return
     */
    List<Map<String, Object>> getAllUserToMap();

    /**
     * 方式二
     */
    @MapKey("id")
    Map<String, Object> getAllUserToMap2();

    /**
     * 测试模糊查询
     */
    List<User> testMohu(@Param("mohu") String mohu);

    /**
     * 批量删除
     */
    int deleteMore(@Param("ids") String ids);

    /**
     * 实现动态表名
     * @param tableName
     * @return
     */
    List<User> getAllUser(@Param("tableName") String tableName);

    /**
     * 添加用户信息
     */
    int insertUser(User user);
}
